ace.define(
  'ace/mode/matching_brace_outdent',
  ['require', 'exports', 'module', 'ace/range'],
  function (require, exports, module) {
    'use strict';
    var Range = require('../range').Range;
    var MatchingBraceOutdent = function () {};
    (function () {
      this.checkOutdent = function (line, input) {
        if (!/^\s+$/.test(line)) return false;
        return /^\s*\}/.test(input);
      };
      this.autoOutdent = function (doc, row) {
        var line = doc.getLine(row);
        var match = line.match(/^(\s*\})/);
        if (!match) return 0;
        var column = match[1].length;
        var openBracePos = doc.findMatchingBracket({ row: row, column: column });
        if (!openBracePos || openBracePos.row == row) return 0;
        var indent = this.$getIndent(doc.getLine(openBracePos.row));
        doc.replace(new Range(row, 0, row, column - 1), indent);
      };
      this.$getIndent = function (line) {
        return line.match(/^\s*/)[0];
      };
    }.call(MatchingBraceOutdent.prototype));
    exports.MatchingBraceOutdent = MatchingBraceOutdent;
  },
);

ace.define(
  'ace/mode/livescript',
  [
    'require',
    'exports',
    'module',
    'ace/tokenizer',
    'ace/mode/matching_brace_outdent',
    'ace/mode/behaviour/cstyle',
    'ace/mode/text',
  ],
  function (require, exports, module) {
    var identifier, LiveScriptMode, keywordend, stringfill;
    identifier = '(?![\\d\\s])[$\\w\\xAA-\\uFFDC](?:(?!\\s)[$\\w\\xAA-\\uFFDC]|-[A-Za-z])*';
    exports.Mode = LiveScriptMode = (function (superclass) {
      var indenter,
        prototype = extend$(
          ((import$(LiveScriptMode, superclass).displayName = 'LiveScriptMode'), LiveScriptMode),
          superclass,
        ).prototype,
        constructor = LiveScriptMode;
      function LiveScriptMode() {
        var that;
        this.$tokenizer = new (require('../tokenizer').Tokenizer)(LiveScriptMode.Rules);
        if ((that = require('../mode/matching_brace_outdent'))) {
          this.$outdent = new that.MatchingBraceOutdent();
        }
        this.$id = 'ace/mode/livescript';
        this.$behaviour = new (require('./behaviour/cstyle').CstyleBehaviour)();
      }
      indenter = RegExp(
        '(?:[({[=:]|[-~]>|\\b(?:e(?:lse|xport)|d(?:o|efault)|t(?:ry|hen)|finally|import(?:\\s*all)?|const|var|let|new|catch(?:\\s*' +
          identifier +
          ')?))\\s*$',
      );
      prototype.getNextLineIndent = function (state, line, tab) {
        var indent, tokens;
        indent = this.$getIndent(line);
        tokens = this.$tokenizer.getLineTokens(line, state).tokens;
        if (!(tokens.length && tokens[tokens.length - 1].type === 'comment')) {
          if (state === 'start' && indenter.test(line)) {
            indent += tab;
          }
        }
        return indent;
      };
      prototype.lineCommentStart = '#';
      prototype.blockComment = { start: '###', end: '###' };
      prototype.checkOutdent = function (state, line, input) {
        var ref$;
        return (ref$ = this.$outdent) != null ? ref$.checkOutdent(line, input) : void 8;
      };
      prototype.autoOutdent = function (state, doc, row) {
        var ref$;
        return (ref$ = this.$outdent) != null ? ref$.autoOutdent(doc, row) : void 8;
      };
      return LiveScriptMode;
    })(require('../mode/text').Mode);
    keywordend = '(?![$\\w]|-[A-Za-z]|\\s*:(?![:=]))';
    stringfill = {
      defaultToken: 'string',
    };
    LiveScriptMode.Rules = {
      start: [
        {
          token: 'keyword',
          regex:
            '(?:t(?:h(?:is|row|en)|ry|ypeof!?)|c(?:on(?:tinue|st)|a(?:se|tch)|lass)|i(?:n(?:stanceof)?|mp(?:ort(?:\\s+all)?|lements)|[fs])|d(?:e(?:fault|lete|bugger)|o)|f(?:or(?:\\s+own)?|inally|unction)|s(?:uper|witch)|e(?:lse|x(?:tends|port)|val)|a(?:nd|rguments)|n(?:ew|ot)|un(?:less|til)|w(?:hile|ith)|o[fr]|return|break|let|var|loop)' +
            keywordend,
        },
        {
          token: 'constant.language',
          regex: '(?:true|false|yes|no|on|off|null|void|undefined)' + keywordend,
        },
        {
          token: 'invalid.illegal',
          regex: '(?:p(?:ackage|r(?:ivate|otected)|ublic)|i(?:mplements|nterface)|enum|static|yield)' + keywordend,
        },
        {
          token: 'language.support.class',
          regex:
            '(?:R(?:e(?:gExp|ferenceError)|angeError)|S(?:tring|yntaxError)|E(?:rror|valError)|Array|Boolean|Date|Function|Number|Object|TypeError|URIError)' +
            keywordend,
        },
        {
          token: 'language.support.function',
          regex: '(?:is(?:NaN|Finite)|parse(?:Int|Float)|Math|JSON|(?:en|de)codeURI(?:Component)?)' + keywordend,
        },
        {
          token: 'variable.language',
          regex: '(?:t(?:hat|il|o)|f(?:rom|allthrough)|it|by|e)' + keywordend,
        },
        {
          token: 'identifier',
          regex: identifier + '\\s*:(?![:=])',
        },
        {
          token: 'variable',
          regex: identifier,
        },
        {
          token: 'keyword.operator',
          regex: '(?:\\.{3}|\\s+\\?)',
        },
        {
          token: 'keyword.variable',
          regex: '(?:@+|::|\\.\\.)',
          next: 'key',
        },
        {
          token: 'keyword.operator',
          regex: '\\.\\s*',
          next: 'key',
        },
        {
          token: 'string',
          regex: '\\\\\\S[^\\s,;)}\\]]*',
        },
        {
          token: 'string.doc',
          regex: "'''",
          next: 'qdoc',
        },
        {
          token: 'string.doc',
          regex: '"""',
          next: 'qqdoc',
        },
        {
          token: 'string',
          regex: "'",
          next: 'qstring',
        },
        {
          token: 'string',
          regex: '"',
          next: 'qqstring',
        },
        {
          token: 'string',
          regex: '`',
          next: 'js',
        },
        {
          token: 'string',
          regex: '<\\[',
          next: 'words',
        },
        {
          token: 'string.regex',
          regex: '//',
          next: 'heregex',
        },
        {
          token: 'comment.doc',
          regex: '/\\*',
          next: 'comment',
        },
        {
          token: 'comment',
          regex: '#.*',
        },
        {
          token: 'string.regex',
          regex:
            '\\/(?:[^[\\/\\n\\\\]*(?:(?:\\\\.|\\[[^\\]\\n\\\\]*(?:\\\\.[^\\]\\n\\\\]*)*\\])[^[\\/\\n\\\\]*)*)\\/[gimy$]{0,4}',
          next: 'key',
        },
        {
          token: 'constant.numeric',
          regex:
            '(?:0x[\\da-fA-F][\\da-fA-F_]*|(?:[2-9]|[12]\\d|3[0-6])r[\\da-zA-Z][\\da-zA-Z_]*|(?:\\d[\\d_]*(?:\\.\\d[\\d_]*)?|\\.\\d[\\d_]*)(?:e[+-]?\\d[\\d_]*)?[\\w$]*)',
        },
        {
          token: 'lparen',
          regex: '[({[]',
        },
        {
          token: 'rparen',
          regex: '[)}\\]]',
          next: 'key',
        },
        {
          token: 'keyword.operator',
          regex: '[\\^!|&%+\\-]+',
        },
        {
          token: 'text',
          regex: '\\s+',
        },
      ],
      heregex: [
        {
          token: 'string.regex',
          regex: '.*?//[gimy$?]{0,4}',
          next: 'start',
        },
        {
          token: 'string.regex',
          regex: '\\s*#{',
        },
        {
          token: 'comment.regex',
          regex: '\\s+(?:#.*)?',
        },
        {
          defaultToken: 'string.regex',
        },
      ],
      key: [
        {
          token: 'keyword.operator',
          regex: '[.?@!]+',
        },
        {
          token: 'identifier',
          regex: identifier,
          next: 'start',
        },
        {
          token: 'text',
          regex: '',
          next: 'start',
        },
      ],
      comment: [
        {
          token: 'comment.doc',
          regex: '.*?\\*/',
          next: 'start',
        },
        {
          defaultToken: 'comment.doc',
        },
      ],
      qdoc: [
        {
          token: 'string',
          regex: ".*?'''",
          next: 'key',
        },
        stringfill,
      ],
      qqdoc: [
        {
          token: 'string',
          regex: '.*?"""',
          next: 'key',
        },
        stringfill,
      ],
      qstring: [
        {
          token: 'string',
          regex: "[^\\\\']*(?:\\\\.[^\\\\']*)*'",
          next: 'key',
        },
        stringfill,
      ],
      qqstring: [
        {
          token: 'string',
          regex: '[^\\\\"]*(?:\\\\.[^\\\\"]*)*"',
          next: 'key',
        },
        stringfill,
      ],
      js: [
        {
          token: 'string',
          regex: '[^\\\\`]*(?:\\\\.[^\\\\`]*)*`',
          next: 'key',
        },
        stringfill,
      ],
      words: [
        {
          token: 'string',
          regex: '.*?\\]>',
          next: 'key',
        },
        stringfill,
      ],
    };
    function extend$(sub, sup) {
      function fun() {}
      fun.prototype = (sub.superclass = sup).prototype;
      (sub.prototype = new fun()).constructor = sub;
      if (typeof sup.extended == 'function') sup.extended(sub);
      return sub;
    }
    function import$(obj, src) {
      var own = {}.hasOwnProperty;
      for (var key in src) if (own.call(src, key)) obj[key] = src[key];
      return obj;
    }
  },
);
(function () {
  ace.require(['ace/mode/livescript'], function (m) {
    if (typeof module == 'object' && typeof exports == 'object' && module) {
      module.exports = m;
    }
  });
})();
